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LISTING OF CLAIMS 

the following listing is for the convenience of the Examiner. No amendments are made 

herein. 

1 .-7. (canceled) 

8. (previously presented) An apparatus according to claim 12, wherein a plurality of 
storage units respectively corresponding to a plurality of executors of said subroutine are 
prepared; and 

said collecting section specifies said executor of said subroutine and stores said profile 
of said subroutine corresponding to said specified executor in said storage unit. 

9. (original) An apparatus according to claim 8, wherein said collecting section 
individually stores profiles of a plurality of subroutines corresponding to a specified executor in 
said storage unit. 

10. (original) An apparatus according to claim 9, wherein said collecting section 
individually stores a first profile of a subroutine called by a main routine, and a second profile of 
the subroutine called by another subroutine, in said storage unit. 

11 . (original) An apparatus according to claim 10, wherein said collecting section 
stores said second profile and calling relationship information relating to said second profile, said 
calling relationship information indicating a relationship between said other subroutine and said 
called subroutine, in said storage unit. 

12. (currently amended) An apparatus for collecting a profile of a subroutine 
included in a program, comprising: 

a storage unit storing a profile; 

an analyzing section, when an interrupt is generated by execution of a branch instruction 
during execution of said program, obtaining a branch source address and a branch destination 
address from a source of said interrupt, and identifying a type of said branch instruction by 
obtaining a instruction code from said branch source address and decoding said instruction 
code; and 

a collecting section obtaining said branch source address, said branch destination 
address, and a identified result from said analyzing section when the identified instruction is a 
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calling instruction or a return instruction of said subroutine; when said identified result is said 
calling instruction, storing said branch destination address as a subroutine address 
corresponding to said calling instruction and a calling time of said subroutine corresponding to 
said calling instruction in said storage unit; and when said identified result is said return 
instruction, obtaining a return time of said subroutine corresponding to said return instruction, 
calculating a execution time of said subroutine based on said obtained return time and said 
calling time, and storing a cumulative value of said execution time as said profile in 
correspondence with said branch destination address in said storage unit; and when the 
identified branch instruction is neither a calling instruction nor a return instruction, said interrupt 
is terminated. 

13. (previously presented) An apparatus according to claim 12, wherein said 
collecting section stores times of calling of said subroutine corresponding to said branch 
destination address as said profile in said storage unit. 

14. (original) An apparatus according to claim 12, wherein said collecting section 
obtains an overhead of said subroutine as said profile and stores said overhead in said storage 
unit. 

15. (previously presented) An apparatus according to claim 13, wherein said 
collecting section, when said identified result is said calling instruction, stores an identifier of an 
executor of said subroutine corresponding to said calling instruction and said branch destination 
address in said storage unit. 

16. (previously presented) An apparatus according to claim 12, wherein said 
collecting section, when said identified result is said calling instruction and said branch source 
address and said branch destination address are addresses of said subroutines, stores said 
branch source address and branch destination address as calling relationship information 
indicating a calling source subroutine and a calling destination subroutine in said storage unit, 
and stores at least one of the cumulative execution time and the times of calling in said calling 
destination subroutine in the call source subroutine, as said profile corresponding to said calling 
relationship information, in said storage unit. 

17. (previously presented) An apparatus according to claim 12, further comprising a 
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setting section setting an execution environment of a source of said interrupt so as to generate 
said interrupt wiien said brancli instruction is executed during tlie execution of said program. 

18. (canceled) 

19. (previously presented) A computer readable medium according to claim 23, 
wherein said computer further executes the process by: 

specifying an executor of said subroutine; and 

storing said profile in a storage unit corresponding to said specified executor within a 
plurality of storage unit provided with each executor. 

20. (previously presented) A computer readable medium according to claim 19, 
wherein said computer further executes the process by storing, when a specified executor 
executes a plurality of subroutines, profiles of said plurality of subroutines in said storage unit 
corresponding to said specified executor. 

21 . (previously presented) A computer readable medium according to claim 20, 
wherein said computer further executes the process of storing a first profile of said subroutine 
called by a main routine and a second profile of said subroutine called by another subroutine In 
said corresponding storage unit, regarding to each of said subroutines. 

22. (previously presented) A computer readable medium according to claim 21 , 
wherein said computer further executes the process by storing said second profile and calling 
relationship Information relating to said second profile, said calling relationship information 
Indicating a relationship between said other subroutine and said subroutine. 

23. (currently amended) A computer readable medium a storing a program for a 
computer executing a process for collecting a profile of a subroutine included in a target 
program, by: 

obtaining a branch source address and a branch destination address from a source of an 
interrupt when said Interrupt is generated by execution of a branch Instruction during execution 
of the target program; 

identifying a type of said branch instruction by obtaining a instruction code from said 
branch source address and decoding said instruction code; 
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storing said brancli destination address as a subroutine address corresponding to said 
calling instruction and a calling time of said subroutine corresponding to said calling instruction 
in a storage unit when said identified result is said calling instruction; and, 

when said identified result is said return instruction, obtaining a return time of said 
subroutine corresponding to said return instruction, calculating a execution time of said 
subroutine based on said obtained return time and said calling time, and storing a cumulative 
value of said execution time as said profile in correspondence with said branch destination 
address in said storage unit; and when the identified branch instruction is neither a calling 
instruction nor a return instruction, said interrupt is terminated. 

24. (previously presented) A computer readable medium according to claim 23, 
wherein said computer further executes the process by storing times of calling of said subroutine 
corresponding to said branch destination address as said profile in said storage unit. 

25. (previously presented) A computer readable medium according to claim 23, 
wherein said program further executes the process by storing an overhead of said subroutine as 
said profile in said storage unit. 

26. (previously presented) A computer readable medium according to claim 23, 
wherein said computer further executes the process by storing, when said identified result is said 
calling instruction, an identifier of an executor of said subroutine corresponding to said calling 
instruction and said branch destination address in said storage unit. 

27. (previously presented) A computer readable medium according to claim 23, 
wherein said computer further executes the process when said identified result is said calling 
instruction and said brunch source address and said branch destination address are addresses 
of said subroutines, storing said branch source address and branch destination address as 
calling relationship information indicating a calling source subroutine, and a calling destination 
subroutine in said storage unit; and storing at least one of the cumulative execution time and the 
times of calling in said calling destination subroutine in the call source subroutine, as said profile 
corresponding to said calling relationship information, in said storage unit. 

28. (previously presented) A computer readable medium according to claim 23, 
wherein said computer further executes the process by setting an execution environment of a 
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source of said interrupt so as to generate said interrupt when said branch instruction is executed 
during the execution of said program. 

29. (canceled) 

30. (previously presented) A method according to claim 34, further comprising: 
specifying an executor of the subroutine; and 

storing the profile in a storage unit corresponding to the specified executor within a 
plurality of storage unit provided with each executor. 

31 . (previously presented) A method according to claim 30, further comprising 
storing, when a specified executor executes a plurality of subroutines, profiles of the plurality of 
subroutines in the storage unit corresponding to the specified executor. 

32. (previously presented) A method according to claim 31 , further comprising 
storing a first profile of the subroutine called out by a main routine and a second profile of the 
subroutine called out by another subroutine in the corresponding storage unit, regarding to each 
of the subroutines. 

33. (previously presented) A method according to claim 32, further comprising 
storing the second profile and calling relationship information relating to the second profile, the 
calling relationship information indicating a relationship between the other subroutine and the 
subroutine. 

34. (currently amended) A method for collecting a profile of a subroutine included in 
a program, comprising: 

obtaining a branch source address and a branch destination address from a source of an 
interrupt when the interrupt is generated by execution of a branch instruction during execution of 
said program; 

identifying a type of the branch instruction by obtaining a instruction code from the branch 
source address and decoding the instruction code; 

storing the branch destination address as a subroutine address corresponding to the 
calling instruction and a calling time of the subroutine corresponding to the calling instruction in a 
storage unit when the identified result is the calling instruction; and 
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when the identified result is the return instruction, obtaining a return time of the 
subroutine corresponding to the return instruction, calculating a execution time of the subroutine 
based on the obtained return time and the calling time, and storing a cumulative value of the 
execution time as the profile in correspondence with the branch destination address in the 
storage unit; and when the identified branch instruction is neither a calling instruction nor a 
return instruction, said interrupt is terminated. 

35. (previously presented) A method according to claim 34, further comprising 
storing times of calling of the subroutine corresponding to the branch destination address as the 
profile in said storage unit. 

36. (previously presented) A method according to claim 34, further comprising 
storing an overhead of the subroutine as the profile in the storage unit. 

37. (previously presented) A method according to claim 34, further comprising step 
©f storing, when the identified result is the calling instruction, an identifier of an executor of the 
subroutine corresponding to the calling instruction and the branch destination address in the 
storage unit. 

38. (previously presented) A method according to claim 34, further comprising, when 
the identified result is the calling instruction and the branch source address and the branch 
destination address are addresses of the subroutines, storing the branch source address and 
the branch destination address as calling relationship information indicating a calling source 
subroutine, and a calling destination subroutine in said storage unit; and storing at least one of 
the cumulative execution time and the times of calling in the calling destination subroutine in the 
call source subroutine, as the profile corresponding to the calling relationship information, in the 
storage unit. 
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39. (previously presented) A method according to claim 34, further comprising 
setting an execution environment of a source of the interrupt so as to generate the interrupt 
when the branch instruction is executed during the execution of the program. 

40. (previously presented) An apparatus according to claim 13, wherein the 
collecting section generates a control table corresponding to each executor of the subroutine on 
the storage unit, 

wherein the control table includes an executor managing table, a subroutine managing 
table, and a calling managing table, 

wherein the executor managing table stores an identifier of the executor and a pointer to 
assign the subroutine managing table, 

wherein the subroutine managing table is generated every subroutine executed by the 
executor, the subroutine managing table storing a subroutine address, times of calling of the 
subroutine, a cumulative execution time of the subroutine, the last called time of the subroutine, 
and a pointer to assign the calling managing table, and 

wherein the calling managing table is generated every subroutine called by the 
subroutine, the calling managing table storing a branch source address as a calling subroutine 
address, a branch destination address as a called subroutine address, times of calling of the 
called subroutine, a cumulative execution time of the called subroutine, the last called time of the 
called subroutine, and a pointer to specify the subroutine managing table managing the calling 
subroutine. 

41 . (previously presented) A computer readable medium according to claim 23, 
wherein the computer further executes the process by generating a control table corresponding 
to each executor of the subroutine on the storage unit, 

wherein the control table includes an executor managing table, a subroutine managing 
table, and a calling managing table, 

wherein the executor managing tables stores an identifier of the executor and a pointer to 
assign the subroutine managing table, 

wherein the subroutine managing table is generated every subroutine executed by the 
executor, the subroutine managing table storing a subroutine address, times of calling of the 
subroutine, a cumulative execution time of the subroutine, the last called time of the subroutine, 
and a pointer to assign the calling managing table, 

wherein the calling managing table is generated every subroutine called by the 
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subroutine, the calling managing table storing a branch source address as a calling subroutine 
address, a branch destination address as a called subroutine address, times of calling of the 
called subroutine, a cumulative execution time of the called subroutine, the last called time of the 
called subroutine, and a pointer to specify the subroutine managing table managing the calling 
subroutine. 

42. (previously presented) A method according to claim 38, wherein the method 
further comprises generating a control table corresponding to each executor of the subroutine on 
the storage unit, 

wherein the control table includes an executor managing table, a subroutine managing 
table, and a calling managing table, 

wherein the executor managing table stores an identifier of the executor and a pointer to 
assign the subroutine managing table, 

wherein the subroutine managing table is generated every subroutine executed by the 
executor, the subroutine managing table storing a subroutine address, times of calling of the 
subroutine, a cumulative execution time of the subroutine, the last called time of the subroutine, 
and a pointer to assign the calling managing table, and 

wherein the calling managing table is generated every subroutine called by the 
subroutine, the calling managing table storing a branch source address as a calling subroutine 
address, a branch destination address as a called subroutine address, times of calling of the 
called subroutine, a cumulative execution time of the called subroutine, the last called time of the 
called subroutine, and a pointer to specify the subroutine managing table managing the calling 
subroutine. 



